package com.ruoyi.system.domain.dao;

import java.util.Date;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.annotation.Excel;
import com.ruoyi.common.core.domain.DtoBaseEntity;
import com.ruoyi.common.core.domain.DtoBaseEntity;

/**
 * 用户信息对象 sys_user
 *
 * @author ruoyi
 * @date 2025-09-02
 */
@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName("sys_user")
public class SysUserDao extends DtoBaseEntity {
        private static final long serialVersionUID = 1L;

        /** 用户ID */
        @TableId(value = "user_id",type = IdType.ASSIGN_ID)
        private String userId;

        /** 部门ID */
        @Excel(name = "部门ID")
        private String deptId;

        /** 用户账号 */
        @Excel(name = "用户账号")
        private String userName;

        /** 用户昵称 */
        @Excel(name = "用户昵称")
        private String nickName;

        /** 用户类型（00系统用户） */
        @Excel(name = "用户类型", readConverterExp = "0=0系统用户")
        private String userType;

        /** 用户邮箱 */
        @Excel(name = "用户邮箱")
        private String email;

        /** $column.columnComment */
        @Excel(name = "${comment}", readConverterExp = "$column.readConverterExp()")
        private String phonenumber;

        /** 用户性别（0男 1女 2未知） */
        @Excel(name = "用户性别", readConverterExp = "0=男,1=女,2=未知")
        private String sex;

        /** 头像地址 */
        @Excel(name = "头像地址")
        private String avatar;

        /** 密码 */
        @Excel(name = "密码")
        private String password;

        /** 帐号状态（0正常 1停用） */
        @Excel(name = "帐号状态", readConverterExp = "0=正常,1=停用")
        private String status;

        /** 删除标志（0代表存在 2代表删除） */
        private String delFlag;

        /** 最后登录IP */
        @Excel(name = "最后登录IP")
        private String loginIp;

        /** 最后登录时间 */
        @JsonFormat(pattern = "yyyy-MM-dd")
        @Excel(name = "最后登录时间", width = 30, dateFormat = "yyyy-MM-dd")
        private Date loginDate;

        /** 最后更新时间 */
        @JsonFormat(pattern = "yyyy-MM-dd")
        @Excel(name = "最后更新时间", width = 30, dateFormat = "yyyy-MM-dd")
        private Date pwdUpdateDate;

        /** 中文全拼 */
        @Excel(name = "中文全拼")
        private String zhFullSpell;

        /** 排序 */
        @Excel(name = "排序")
        private Float orderNum;

        /** 旧数据 */
        @Excel(name = "旧数据")
        private String oldData;

}